package Top_Interview_Questions.Array;

/**
 * @Author: 吕庆龙
 * @Date: 2020/3/14 15:51
 * <p>
 * 功能描述:
 */
public class _0162 {

    public static void main(String[] args) {
        _0162 test = new _0162();
        int[] nums = {1,2,1,3,5,6,4};
        int index = test.findPeakElement(nums);
    }

    /**
     * 输入: nums = [1,2,1,3,5,6,4]
     * 输出: 1 或 5
     * 解释: 你的函数可以返回索引 1，其峰值元素为 2；
     *      或者返回索引 5， 其峰值元素为 6。

     */
    public int findPeakElement(int[] nums) {
        int left = 0, right = nums.length - 1;
        while (left < right) {
            int mid = left + (right - left) / 2;
            if (nums[mid] > nums[mid + 1]) {
                right = mid;
            } else {
                left = mid + 1;
            }
        }
        return left; //这里return right也可以
    }

}
